<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>珠峰架构师成长计划</title>
    <link rel="stylesheet" type="text/css" href="../static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            珠峰架构师成长计划
        
    </div>
<ul><li><a href="../index.html">0.Async</a></li><li><a href="../html/0.editor.html">0.editor</a></li><li><a href="../html/0.module.html">0.module</a></li><li><a href="../html/1.ES2015.html">1.ES2015</a></li><li><a href="../html/2.Promise.html">2.Promise</a></li><li><a href="../html/3.Node.html">3.Node</a></li><li><a href="../html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="../html/5.REPL.html">5.REPL</a></li><li><a href="../html/6.NodeCore.html">6.NodeCore</a></li><li><a href="../html/7.module&NPM.html">7.module&NPM</a></li><li><a href="../html/8.Encoding.html">8.Encoding</a></li><li><a href="../html/9.Buffer.html">9.Buffer</a></li><li><a href="../html/10.fs.html">10.fs</a></li><li><a href="../html/11.Stream-1.html">11.Stream-1</a></li><li><a href="../html/11.Stream-2.html">11.Stream-2</a></li><li><a href="../html/11.Stream-3.html">11.Stream-3</a></li><li><a href="../html/11.Stream-4.html">11.Stream-4</a></li><li><a href="../html/12-Network-2.html">12-Network-2</a></li><li><a href="../html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="../html/12.Network-1.html">12.Network-1</a></li><li><a href="../html/13.tcp.html">13.tcp</a></li><li><a href="../html/14.http-1.html">14.http-1</a></li><li><a href="../html/14.http-2.html">14.http-2</a></li><li><a href="../html/15.compress.html">15.compress</a></li><li><a href="../html/16.crypto.html">16.crypto</a></li><li><a href="../html/17.process.html">17.process</a></li><li><a href="../html/18.yargs.html">18.yargs</a></li><li><a href="../html/19.cache.html">19.cache</a></li><li><a href="../html/20.action.html">20.action</a></li><li><a href="../html/21.https.html">21.https</a></li><li><a href="../html/22.cookie.html">22.cookie</a></li><li><a href="../html/23.session.html">23.session</a></li><li><a href="../html/24.express-1.html">24.express-1</a></li><li><a href="../html/24.express-2.html">24.express-2</a></li><li><a href="../html/24.express-3.html">24.express-3</a></li><li><a href="../html/24.express-4.html">24.express-4</a></li><li><a href="../html/25.koa-1.html">25.koa-1</a></li><li><a href="../html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="../html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="../html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="../html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="../html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="../html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="../html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="../html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="../html/27.react-1.html">27.react-1</a></li><li><a href="../html/27.react-2.html">27.react-2</a></li><li><a href="../html/27.react-3.html">27.react-3</a></li><li><a href="../html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="../html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="../html/27.react-6.html">27.react-6</a></li><li><a href="../html/28.react-mobx.html">28.react-mobx</a></li><li><a href="../html/28.redux-0.html">28.redux-0</a></li><li><a href="../html/28.redux-1.html">28.redux-1</a></li><li><a href="../html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="../html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="../html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="../html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="../html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="../html/29.mongodb-2.html">29.mongodb-2</a></li><li><a href="../html/29.mongodb-3.html">29.mongodb-3</a></li><li class="active"><a href="../html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="../html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="../html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="../html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="../html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="../html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="../html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="../html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="../html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="../html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="../html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="../html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="../html/30.cms-10-front.html">30.cms-10-front</a></li><li><a href="../html/30.cms-11-deploy.html">30.cms-11-deploy</a></li><li><a href="../html/33.redis.html">33.redis</a></li><li><a href="../html/34.unittest.html">34.unittest</a></li><li><a href="../html/35.jwt.html">35.jwt</a></li><li><a href="../html/36.websocket-1.html">36.websocket-1</a></li><li><a href="../html/36.websocket-2.html">36.websocket-2</a></li><li><a href="../html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="../html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="../html/38.chat-3.html">38.chat-3</a></li><li><a href="../html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="../html/38.chat.html">38.chat</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/39.crawl-0.html">39.crawl-0</a></li><li><a href="../html/39.crawl-1.html">39.crawl-1</a></li><li><a href="../html/39.crawl-2.html">39.crawl-2</a></li><li><a href="../html/40.deploy.html">40.deploy</a></li><li><a href="../html/41.safe.html">41.safe</a></li><li><a href="../html/42.test.html">42.test</a></li><li><a href="../html/43.nginx.html">43.nginx</a></li><li><a href="../html/44.enzyme.html">44.enzyme</a></li><li><a href="../html/45.docker.html">45.docker</a></li><li><a href="../html/46.elastic.html">46.elastic</a></li><li><a href="../html/47.oauth.html">47.oauth</a></li><li><a href="../html/48.wxpay.html">48.wxpay</a></li><li><a href="../html/49.nunjucks.html">49.nunjucks</a></li><li><a href="../html/50.ketang.html">50.ketang</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/51.typescript.html">51.typescript</a></li><li><a href="../html/52.UML.html">52.UML</a></li><li><a href="../html/53.design.html">53.design</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/54.linux.html">54.linux</a></li><li><a href="../html/55.yaml.html">55.yaml</a></li><li><a href="../html/50.ketang2.html">50.ketang2</a></li><li><a href="../html/56.ts.html">56.ts</a></li><li><a href="../html/57.ts_react.html">57.ts_react</a></li><li><a href="../html/58.react-ssr.html">58.react-ssr</a></li><li><a href="../html/59.react-ssr.html">59.react-ssr</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. 主从复制">1. 主从复制</a><ul><li><a href="#t11.1 主服务器">1.1 主服务器</a></li><li><a href="#t21.2 从服务器">1.2 从服务器</a></li><li><a href="#t31.3 主从复制的其它设置项">1.3 主从复制的其它设置项</a></li><li><a href="#t41.4 利用shell动态添加和删除主节点">1.4 利用shell动态添加和删除主节点</a></li></ul></li><li><a href="#t52. 副本集">2. 副本集</a><ul><li><a href="#t62.1 MongoDB复制原理">2.1 MongoDB复制原理</a></li><li><a href="#t72.1 流程">2.1 流程</a></li><li><a href="#t82.2 配置副本集">2.2 配置副本集</a></li><li><a href="#t92.3 初始化副本集">2.3 初始化副本集</a></li><li><a href="#t102.4 高级参数">2.4 高级参数</a></li><li><a href="#t112.5 读写分离操作">2.5 读写分离操作</a></li><li><a href="#t122.6 Oplog">2.6 Oplog</a></li></ul></li><li><a href="#t133. 分片">3. 分片</a><ul><li><a href="#t143.1 分片架构图">3.1 分片架构图</a></li><li><a href="#t153.2 片键">3.2 片键</a></li><li><a href="#t163.3  分片的应用场景">3.3  分片的应用场景</a></li><li><a href="#t173.4  配置">3.4  配置</a><ul><li><a href="#t183.4.1 创建Sharding副本集">3.4.1 创建Sharding副本集</a></li><li><a href="#t193.4.2 创建一个配置服务器">3.4.2 创建一个配置服务器</a></li><li><a href="#t203.4.2 创建路由服务器，并且连接配置服务器">3.4.2 创建路由服务器，并且连接配置服务器</a></li><li><a href="#t213.4.3 添加分片数据库">3.4.3 添加分片数据库</a></li><li><a href="#t223.4.5 在路由服务器打开数据分片功能">3.4.5 在路由服务器打开数据分片功能</a></li></ul></li></ul></li><li><a href="#t234. 参考">4. 参考</a></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. &#x4E3B;&#x4ECE;&#x590D;&#x5236;">1. &#x4E3B;&#x4ECE;&#x590D;&#x5236; <a href="#t01. &#x4E3B;&#x4ECE;&#x590D;&#x5236;"> # </a></h2>
<p>&#x4E3B;&#x4ECE;&#x590D;&#x5236;&#x662F;&#x4E00;&#x4E2A;&#x7B80;&#x5355;&#x7684;&#x6570;&#x636E;&#x5E93;&#x540C;&#x6B65;&#x5907;&#x4EFD;&#x7684;&#x96C6;&#x7FA4;&#x6280;&#x672F;</p>
<ul>
<li>&#x5728;&#x6570;&#x636E;&#x5E93;&#x96C6;&#x7FA4;&#x4E2D;&#x8981;&#x660E;&#x786E;&#x77E5;&#x9053;&#x8C01;&#x662F;&#x4E3B;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x4E3B;&#x670D;&#x52A1;&#x5668;&#x53EA;&#x6709;&#x4E00;&#x53F0;</li>
<li>&#x4ECE;&#x670D;&#x52A1;&#x5668;&#x8981;&#x77E5;&#x9053;&#x81EA;&#x5DF1;&#x7684;&#x6570;&#x636E;&#x6E90;&#x4E5F;&#x5C31;&#x662F;&#x77E5;&#x9053;&#x81EA;&#x5DF1;&#x7684;&#x4E3B;&#x670D;&#x52A1;&#x5668;&#x662F;&#x8C01;</li>
<li>--master&#x7528;&#x6765;&#x786E;&#x5B9A;&#x4E3B;&#x670D;&#x52A1;&#x5668;&#xFF0C;--slave&#x548C;--source &#x6765;&#x63A7;&#x5236;&#x4ECE;&#x670D;&#x52A1;&#x5668;</li>
</ul>
<p><img src="http://img.zhufengpeixun.cn/masterslave.jpg" alt="masterslave"></p>
<h3 id="t11.1 &#x4E3B;&#x670D;&#x52A1;&#x5668;">1.1 &#x4E3B;&#x670D;&#x52A1;&#x5668; <a href="#t11.1 &#x4E3B;&#x670D;&#x52A1;&#x5668;"> # </a></h3>
<p>master.conf</p>
<pre><code class="lang-js">dbpath=E:\ms\master
port=<span class="hljs-number">1000</span>
master=<span class="hljs-literal">true</span>
</code></pre>
<p>master.bat</p>
<pre><code class="lang-js">mongod --config master.conf
</code></pre>
<h3 id="t21.2 &#x4ECE;&#x670D;&#x52A1;&#x5668;">1.2 &#x4ECE;&#x670D;&#x52A1;&#x5668; <a href="#t21.2 &#x4ECE;&#x670D;&#x52A1;&#x5668;"> # </a></h3>
<p>slave.conf</p>
<pre><code class="lang-js">dbpath=E:\p\slave
port=<span class="hljs-number">1001</span>
slave=<span class="hljs-literal">true</span>
source=<span class="hljs-number">127.0</span><span class="hljs-number">.0</span><span class="hljs-number">.1</span>:<span class="hljs-number">1000</span>
</code></pre>
<p>slave.bat</p>
<pre><code class="lang-js">mongod --config slave.conf
rs.slaveOk();
</code></pre>
<h3 id="t31.3 &#x4E3B;&#x4ECE;&#x590D;&#x5236;&#x7684;&#x5176;&#x5B83;&#x8BBE;&#x7F6E;&#x9879;">1.3 &#x4E3B;&#x4ECE;&#x590D;&#x5236;&#x7684;&#x5176;&#x5B83;&#x8BBE;&#x7F6E;&#x9879; <a href="#t31.3 &#x4E3B;&#x4ECE;&#x590D;&#x5236;&#x7684;&#x5176;&#x5B83;&#x8BBE;&#x7F6E;&#x9879;"> # </a></h3>
<ul>
<li>-only &#x4ECE;&#x8282;&#x70B9;-&gt; &#x6307;&#x5B9A;&#x590D;&#x5236;&#x67D0;&#x4E2A;&#x6570;&#x636E;&#x5E93;&#x9ED8;&#x8BA4;&#x662F;&#x590D;&#x5236;&#x5168;&#x90E8;&#x6570;&#x636E;&#x5E93;</li>
<li>-slavedelay &#x4ECE;&#x8282;&#x70B9;-&gt; &#x8BBE;&#x7F6E;&#x4E3B;&#x6570;&#x636E;&#x5E93;&#x540C;&#x6B65;&#x6570;&#x636E;&#x7684;&#x5EF6;&#x8FDF;(&#x5355;&#x4F4D;&#x662F;&#x79D2;)</li>
<li>-fastsync &#x4ECE;&#x8282;&#x70B9;-&gt; &#x4EE5;&#x4E3B;&#x6570;&#x636E;&#x5E93;&#x7684;&#x8282;&#x70B9;&#x5FEB;&#x7167;&#x4E3A;&#x8282;&#x70B9;&#x542F;&#x52A8;&#x4ECE;&#x6570;&#x636E;&#x5E93;</li>
<li>-autoresync &#x4ECE;&#x8282;&#x70B9;-&gt;&#x5982;&#x679C;&#x4E0D;&#x540C;&#x6B65;&#x5219;&#x91CD;&#x65B0;&#x540C;&#x6B65;&#x6570;&#x636E;&#x5E93;</li>
<li>-oplogSize &#x4E3B;&#x8282;&#x70B9;-&gt;&#x8BBE;&#x7F6E;oplog&#x7684;&#x5927;&#x5C0F;(&#x4E3B;&#x8282;&#x70B9;&#x64CD;&#x4F5C;&#x8BB0;&#x5F55;&#x5B58;&#x50A8;&#x5230;local&#x7684;oplog&#x4E2D;)</li>
</ul>
<h3 id="t41.4 &#x5229;&#x7528;shell&#x52A8;&#x6001;&#x6DFB;&#x52A0;&#x548C;&#x5220;&#x9664;&#x4E3B;&#x8282;&#x70B9;">1.4 &#x5229;&#x7528;shell&#x52A8;&#x6001;&#x6DFB;&#x52A0;&#x548C;&#x5220;&#x9664;&#x4E3B;&#x8282;&#x70B9; <a href="#t41.4 &#x5229;&#x7528;shell&#x52A8;&#x6001;&#x6DFB;&#x52A0;&#x548C;&#x5220;&#x9664;&#x4E3B;&#x8282;&#x70B9;"> # </a></h3>
<p>&#x767B;&#x5F55;&#x4ECE;&#x670D;&#x52A1;&#x5668; </p>
<pre><code class="lang-js">use local;
show collections;
db.sources.find();
<span class="hljs-comment">//{  &quot;host&quot; : &quot;127.0.0.1:8000&quot;, &quot;source&quot; : &quot;main&quot;, &quot;syncedTo&quot; : Timestamp(1524728329, 1) }</span>
db.sources.insert({<span class="hljs-attr">host</span>:<span class="hljs-string">&apos;127.0.0.1:8000&apos;</span>});<span class="hljs-comment">//&#x6302;&#x8F7D;&#x4E3B;&#x8282;&#x70B9;</span>
db.sources.remove({<span class="hljs-attr">host</span>:<span class="hljs-string">&apos;127.0.0.1:8000&apos;</span>});<span class="hljs-comment">//&#x5220;&#x9664;&#x5DF2;&#x7ECF;&#x6302;&#x8F7D;&#x7684;&#x4E3B;&#x8282;&#x70B9;</span>
</code></pre>
<h2 id="t52. &#x526F;&#x672C;&#x96C6;">2. &#x526F;&#x672C;&#x96C6; <a href="#t52. &#x526F;&#x672C;&#x96C6;"> # </a></h2>
<ul>
<li>MongoDB&#x590D;&#x5236;&#x662F;&#x5C06;&#x6570;&#x636E;&#x540C;&#x6B65;&#x5728;&#x591A;&#x4E2A;&#x670D;&#x52A1;&#x5668;&#x7684;&#x8FC7;&#x7A0B;&#x3002;</li>
<li>&#x590D;&#x5236;&#x63D0;&#x4F9B;&#x4E86;&#x6570;&#x636E;&#x7684;&#x5197;&#x4F59;&#x5907;&#x4EFD;&#xFF0C;&#x5E76;&#x5728;&#x591A;&#x4E2A;&#x670D;&#x52A1;&#x5668;&#x4E0A;&#x5B58;&#x50A8;&#x6570;&#x636E;&#x526F;&#x672C;&#xFF0C;&#x63D0;&#x9AD8;&#x4E86;&#x6570;&#x636E;&#x7684;&#x53EF;&#x7528;&#x6027;&#xFF0C; &#x5E76;&#x53EF;&#x4EE5;&#x4FDD;&#x8BC1;&#x6570;&#x636E;&#x7684;&#x5B89;&#x5168;&#x6027;&#x3002;</li>
<li>&#x590D;&#x5236;&#x8FD8;&#x5141;&#x8BB8;&#x60A8;&#x4ECE;&#x786C;&#x4EF6;&#x6545;&#x969C;&#x548C;&#x670D;&#x52A1;&#x4E2D;&#x65AD;&#x4E2D;&#x6062;&#x590D;&#x6570;&#x636E;&#x3002;</li>
</ul>
<h3 id="t62.1 MongoDB&#x590D;&#x5236;&#x539F;&#x7406;">2.1 MongoDB&#x590D;&#x5236;&#x539F;&#x7406; <a href="#t62.1 MongoDB&#x590D;&#x5236;&#x539F;&#x7406;"> # </a></h3>
<ul>
<li>mongodb&#x7684;&#x590D;&#x5236;&#x81F3;&#x5C11;&#x9700;&#x8981;&#x4E24;&#x4E2A;&#x8282;&#x70B9;&#x3002;&#x5176;&#x4E2D;&#x4E00;&#x4E2A;&#x662F;&#x4E3B;&#x8282;&#x70B9;&#xFF0C;&#x8D1F;&#x8D23;&#x5904;&#x7406;&#x5BA2;&#x6237;&#x7AEF;&#x8BF7;&#x6C42;&#xFF0C;&#x5176;&#x4F59;&#x7684;&#x90FD;&#x662F;&#x4ECE;&#x8282;&#x70B9;&#xFF0C;&#x8D1F;&#x8D23;&#x590D;&#x5236;&#x4E3B;&#x8282;&#x70B9;&#x4E0A;&#x7684;&#x6570;&#x636E;&#x3002;</li>
<li>mongodb&#x5404;&#x4E2A;&#x8282;&#x70B9;&#x5E38;&#x89C1;&#x7684;&#x642D;&#x914D;&#x65B9;&#x5F0F;&#x4E3A;&#xFF1A;&#x4E00;&#x4E3B;&#x4E00;&#x4ECE;&#x3001;&#x4E00;&#x4E3B;&#x591A;&#x4ECE;&#x3002;</li>
<li>&#x4E3B;&#x8282;&#x70B9;&#x8BB0;&#x5F55;&#x5728;&#x5176;&#x4E0A;&#x7684;&#x6240;&#x6709;&#x64CD;&#x4F5C;oplog&#xFF0C;&#x4ECE;&#x8282;&#x70B9;&#x5B9A;&#x671F;&#x8F6E;&#x8BE2;&#x4E3B;&#x8282;&#x70B9;&#x83B7;&#x53D6;&#x8FD9;&#x4E9B;&#x64CD;&#x4F5C;&#xFF0C;&#x7136;&#x540E;&#x5BF9;&#x81EA;&#x5DF1;&#x7684;&#x6570;&#x636E;&#x526F;&#x672C;&#x6267;&#x884C;&#x8FD9;&#x4E9B;&#x64CD;&#x4F5C;&#xFF0C;&#x4ECE;&#x800C;&#x4FDD;&#x8BC1;&#x4ECE;&#x8282;&#x70B9;&#x7684;&#x6570;&#x636E;&#x4E0E;&#x4E3B;&#x8282;&#x70B9;&#x4E00;&#x81F4;&#x3002;</li>
<li><img src="http://img.zhufengpeixun.cn/replication.png" alt="replication"></li>
</ul>
<h3 id="t72.1 &#x6D41;&#x7A0B;">2.1 &#x6D41;&#x7A0B; <a href="#t72.1 &#x6D41;&#x7A0B;"> # </a></h3>
<ol>
<li>&#x4E00;&#x53F0;&#x6D3B;&#x8DC3;&#x670D;&#x52A1;&#x5668;&#x548C;&#x4E8C;&#x4E2A;&#x5907;&#x4EFD;&#x670D;&#x52A1;&#x5668;</li>
<li>&#x5F53;&#x6D3B;&#x8DC3;&#x670D;&#x52A1;&#x5668;&#x51FA;&#x73B0;&#x6545;&#x969C;&#xFF0C;&#x8FD9;&#x65F6;&#x96C6;&#x7FA4;&#x6839;&#x636E;&#x6743;&#x91CD;&#x7B97;&#x6CD5;&#x63A8;&#x9009;&#x51FA;&#x51FA;&#x6D3B;&#x8DC3;&#x670D;&#x52A1;&#x5668;</li>
<li>&#x5F53;&#x539F;&#x6765;&#x7684;&#x4E3B;&#x670D;&#x52A1;&#x5668;&#x6062;&#x590D;&#x540E;&#x53C8;&#x4F1A;&#x53D8;&#x6210;&#x4ECE;&#x670D;&#x52A1;&#x5668;</li>
</ol>
<h3 id="t82.2 &#x914D;&#x7F6E;&#x526F;&#x672C;&#x96C6;">2.2 &#x914D;&#x7F6E;&#x526F;&#x672C;&#x96C6; <a href="#t82.2 &#x914D;&#x7F6E;&#x526F;&#x672C;&#x96C6;"> # </a></h3>
<p>A&#x670D;&#x52A1;&#x5668;</p>
<pre><code class="lang-js">dbpath=E:\repl\repl1
port=<span class="hljs-number">2001</span>
replSet=group
</code></pre>
<p>B&#x670D;&#x52A1;&#x5668;</p>
<pre><code class="lang-js">dbpath=E:\repl\repl2
port=<span class="hljs-number">2002</span>
replSet=group
</code></pre>
<p>C&#x670D;&#x52A1;&#x5668;</p>
<pre><code class="lang-js">dbpath=E:\repl\repl3
port=<span class="hljs-number">2003</span>
replSet=group
</code></pre>
<h3 id="t92.3 &#x521D;&#x59CB;&#x5316;&#x526F;&#x672C;&#x96C6;">2.3 &#x521D;&#x59CB;&#x5316;&#x526F;&#x672C;&#x96C6; <a href="#t92.3 &#x521D;&#x59CB;&#x5316;&#x526F;&#x672C;&#x96C6;"> # </a></h3>
<ul>
<li>rs.initiate() &#x542F;&#x52A8;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x526F;&#x672C;&#x96C6;</li>
<li>rs.conf() &#x67E5;&#x770B;&#x526F;&#x672C;&#x96C6;&#x7684;&#x914D;&#x7F6E;</li>
<li>rs.status() &#x547D;&#x4EE4;</li>
</ul>
<pre><code class="lang-js">use admin;
<span class="hljs-keyword">var</span> conf=
{
    <span class="hljs-string">&quot;_id&quot;</span> : <span class="hljs-string">&quot;group&quot;</span>,
    <span class="hljs-string">&quot;members&quot;</span> : [
        { <span class="hljs-string">&quot;_id&quot;</span> : <span class="hljs-number">0</span>,  <span class="hljs-string">&quot;host&quot;</span> : <span class="hljs-string">&quot;127.0.0.1:2001&quot;</span>  },
        { <span class="hljs-string">&quot;_id&quot;</span> : <span class="hljs-number">1</span>,  <span class="hljs-string">&quot;host&quot;</span> : <span class="hljs-string">&quot;127.0.0.1:2002&quot;</span>  },
        { <span class="hljs-string">&quot;_id&quot;</span> : <span class="hljs-number">2</span>,  <span class="hljs-string">&quot;host&quot;</span> : <span class="hljs-string">&quot;127.0.0.1:2003&quot;</span>  }
    ]
}
rs.initiate(conf);
rs.status();
</code></pre>
<h3 id="t102.4 &#x9AD8;&#x7EA7;&#x53C2;&#x6570;">2.4 &#x9AD8;&#x7EA7;&#x53C2;&#x6570; <a href="#t102.4 &#x9AD8;&#x7EA7;&#x53C2;&#x6570;"> # </a></h3>
<ul>
<li>standard &#x5E38;&#x89C4;&#x8282;&#x70B9; &#x53C2;&#x4E0E;&#x6295;&#x7968;&#x6709;&#x53EF;&#x80FD;&#x6210;&#x4E3A;&#x6D3B;&#x8DC3;&#x8282;&#x70B9;</li>
<li>passive &#x526F;&#x672C;&#x8282;&#x70B9; &#x53C2;&#x4E0E;&#x6295;&#x7968;&#xFF0C;&#x4F46;&#x4E0D;&#x80FD;&#x6210;&#x4E3A;&#x6D3B;&#x8DC3;&#x8282;&#x70B9;</li>
<li>arbiter &#x4EF2;&#x88C1;&#x8282;&#x70B9; &#x53EA;&#x53C2;&#x4E0E;&#x6295;&#x7968;&#xFF0C;&#x4E0D;&#x590D;&#x5236;&#x8282;&#x70B9;&#xFF0C;&#x4E5F;&#x4E0D;&#x80FD;&#x6210;&#x4E3A;&#x6D3B;&#x8DC3;&#x8282;&#x70B9;</li>
<li>priority 0&#x5230;1000&#x4E4B;&#x95F4;&#xFF0C;0&#x4EE3;&#x8868;&#x662F;&#x526F;&#x672C;&#x8282;&#x70B9;&#xFF0C;1&#x5230;1000&#x662F;&#x5E38;&#x89C4;&#x8282;&#x70B9;</li>
<li>arbiterOnly:true &#x4EF2;&#x88C1;&#x8282;&#x70B9;</li>
</ul>
<h3 id="t112.5 &#x8BFB;&#x5199;&#x5206;&#x79BB;&#x64CD;&#x4F5C;">2.5 &#x8BFB;&#x5199;&#x5206;&#x79BB;&#x64CD;&#x4F5C; <a href="#t112.5 &#x8BFB;&#x5199;&#x5206;&#x79BB;&#x64CD;&#x4F5C;"> # </a></h3>
<p>&#x4E00;&#x822C;&#x60C5;&#x51B5;&#x4E0B;&#x4F5C;&#x4E3A;&#x526F;&#x672C;&#x8282;&#x70B9;&#x662F;&#x4E0D;&#x80FD;&#x8FDB;&#x884C;&#x6570;&#x636E;&#x5E93;&#x64CD;&#x4F5C;&#x7684;&#xFF0C;&#x4F46;&#x662F;&#x5728;&#x8BFB;&#x53D6;&#x5BC6;&#x96C6;&#x7684;&#x7CFB;&#x7EDF;&#x4E2D;&#x8BFB;&#x5199;&#x5206;&#x79BB;&#x662F;&#x5FC5;&#x8981;&#x7684;</p>
<pre><code class="lang-js"> rs.slaveOk();
</code></pre>
<h3 id="t122.6 Oplog">2.6 Oplog <a href="#t122.6 Oplog"> # </a></h3>
<p>&#x5B83;&#x88AB;&#x5B58;&#x50A8;&#x5728;&#x672C;&#x5730;&#x6570;&#x636E;&#x5E93;local&#x4E2D;&#xFF0C;&#x4F1A;&#x8BB0;&#x5F55;&#x6BCF;&#x4E00;&#x4E2A;&#x64CD;&#x4F5C;&#x3002;
&#x5982;&#x679C;&#x5E0C;&#x671B;&#x5728;&#x6545;&#x969C;&#x6062;&#x590D;&#x7684;&#x65F6;&#x5019;&#x5C3D;&#x53EF;&#x80FD;&#x66F4;&#x591A;&#xFF0C;&#x53EF;&#x4EE5;&#x628A;&#x8FD9;&#x4E2A;size&#x8BBE;&#x7F6E;&#x7684;&#x5927;&#x4E00;&#x70B9;</p>
<pre><code class="lang-js">--oplogSize <span class="hljs-number">1024</span>
use local;
 db.oplog.rs.find().limit(<span class="hljs-number">2</span>);
</code></pre>
<h2 id="t133. &#x5206;&#x7247;">3. &#x5206;&#x7247; <a href="#t133. &#x5206;&#x7247;"> # </a></h2>
<p>&#x5728;Mongodb&#x91CC;&#x9762;&#x5B58;&#x5728;&#x53E6;&#x4E00;&#x79CD;&#x96C6;&#x7FA4;&#xFF0C;&#x5C31;&#x662F;&#x5206;&#x7247;&#x6280;&#x672F;,&#x53EF;&#x4EE5;&#x6EE1;&#x8DB3;MongoDB&#x6570;&#x636E;&#x91CF;&#x5927;&#x91CF;&#x589E;&#x957F;&#x7684;&#x9700;&#x6C42;&#x3002;
&#x5F53;MongoDB&#x5B58;&#x50A8;&#x6D77;&#x91CF;&#x7684;&#x6570;&#x636E;&#x65F6;&#xFF0C;&#x4E00;&#x53F0;&#x673A;&#x5668;&#x53EF;&#x80FD;&#x4E0D;&#x8DB3;&#x4EE5;&#x5B58;&#x50A8;&#x6570;&#x636E;&#xFF0C;&#x4E5F;&#x53EF;&#x80FD;&#x4E0D;&#x8DB3;&#x4EE5;&#x63D0;&#x4F9B;&#x53EF;&#x63A5;&#x53D7;&#x7684;&#x8BFB;&#x5199;&#x541E;&#x5410;&#x91CF;&#x3002;&#x8FD9;&#x65F6;&#xFF0C;&#x6211;&#x4EEC;&#x5C31;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x5728;&#x591A;&#x53F0;&#x673A;&#x5668;&#x4E0A;&#x5206;&#x5272;&#x6570;&#x636E;&#xFF0C;&#x4F7F;&#x5F97;&#x6570;&#x636E;&#x5E93;&#x7CFB;&#x7EDF;&#x80FD;&#x5B58;&#x50A8;&#x548C;&#x5904;&#x7406;&#x66F4;&#x591A;&#x7684;&#x6570;&#x636E;&#x3002;</p>
<h3 id="t143.1 &#x5206;&#x7247;&#x67B6;&#x6784;&#x56FE;">3.1 &#x5206;&#x7247;&#x67B6;&#x6784;&#x56FE; <a href="#t143.1 &#x5206;&#x7247;&#x67B6;&#x6784;&#x56FE;"> # </a></h3>
<p><img src="http://img.zhufengpeixun.cn/sharding.png" alt="sharding"></p>
<h3 id="t153.2 &#x7247;&#x952E;">3.2 &#x7247;&#x952E; <a href="#t153.2 &#x7247;&#x952E;"> # </a></h3>
<p>&#x8DEF;&#x7531;&#x6839;&#x636E;&#x7247;&#x952E;&#x628A;&#x4E0D;&#x540C;&#x7684;&#x6587;&#x6863;&#x4FDD;&#x5B58;&#x5230;&#x4E0D;&#x540C;&#x7684;&#x5206;&#x7247;&#x4E2D;</p>
<h3 id="t163.3  &#x5206;&#x7247;&#x7684;&#x5E94;&#x7528;&#x573A;&#x666F;">3.3  &#x5206;&#x7247;&#x7684;&#x5E94;&#x7528;&#x573A;&#x666F; <a href="#t163.3  &#x5206;&#x7247;&#x7684;&#x5E94;&#x7528;&#x573A;&#x666F;"> # </a></h3>
<ol>
<li>&#x5355;&#x53F0;&#x673A;&#x5668;&#x65E0;&#x6CD5;&#x5B58;&#x50A8;</li>
<li>&#x5355;&#x53F0;&#x673A;&#x5668;&#x5DF2;&#x7ECF;&#x4E0D;&#x80FD;&#x6EE1;&#x8DB3;&#x9AD8;&#x5E76;&#x53D1;&#x64CD;&#x4F5C;</li>
<li>&#x60F3;&#x628A;&#x5C3D;&#x53EF;&#x80FD;&#x591A;&#x7684;&#x6570;&#x636E;&#x5B58;&#x653E;&#x5230;&#x5185;&#x5B58;&#x4E2D;&#x63D0;&#x9AD8;&#x6027;&#x80FD;</li>
</ol>
<h3 id="t173.4  &#x914D;&#x7F6E;">3.4  &#x914D;&#x7F6E; <a href="#t173.4  &#x914D;&#x7F6E;"> # </a></h3>
<h4 id="t183.4.1 &#x521B;&#x5EFA;Sharding&#x526F;&#x672C;&#x96C6;">3.4.1 &#x521B;&#x5EFA;Sharding&#x526F;&#x672C;&#x96C6; <a href="#t183.4.1 &#x521B;&#x5EFA;Sharding&#x526F;&#x672C;&#x96C6;"> # </a></h4>
<pre><code class="lang-js">mkdir E:\repl\db2001
mongod --port <span class="hljs-number">2001</span> --dbpath=<span class="hljs-regexp">/data/</span>db2001  --shardsvr --replSet=shard1
mkdir E:\repl/db2002
mongod --port <span class="hljs-number">2002</span> --dbpath=<span class="hljs-regexp">/data/</span>db2002 --shardsvr --replSet=shard1
</code></pre>
<pre><code class="lang-js"># mongo localhost:2001
rs.initiate({_id: &apos;shard1&apos;, members: [{_id: 0, host: &apos;localhost:2001&apos;}, {_id: 1, host: &apos;localhost:2002&apos;}]})
rs.isMaster() #&#x67E5;&#x770B;&#x4E3B;&#x4ECE;&#x5173;&#x7CFB;
</code></pre>
<pre><code class="lang-js">mkdir E:\repl\db2003
mongod --port <span class="hljs-number">2003</span> --dbpath=E:\repl\db2003  --shardsvr --replSet=shard2
mkdir E:\repl\db2004
mongod --port <span class="hljs-number">2004</span> --dbpath=E:\repl\db2004 --shardsvr --replSet=shard2
</code></pre>
<pre><code class="lang-js"># mongo localhost:2003
rs.initiate({_id: &apos;shard2&apos;, members: [{_id: 0, host: &apos;localhost:2003&apos;}, {_id: 1, host: &apos;localhost:2004&apos;}]})
rs.isMaster() #&#x67E5;&#x770B;&#x4E3B;&#x4ECE;&#x5173;&#x7CFB;
</code></pre>
<h4 id="t193.4.2 &#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x914D;&#x7F6E;&#x670D;&#x52A1;&#x5668;">3.4.2 &#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x914D;&#x7F6E;&#x670D;&#x52A1;&#x5668; <a href="#t193.4.2 &#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x914D;&#x7F6E;&#x670D;&#x52A1;&#x5668;"> # </a></h4>
<pre><code class="lang-js">mkdir E:\repl\db2005
mongod --port <span class="hljs-number">2005</span> --dbpath=E:\repl\db2005  --shardsvr --replSet=config
mkdir E:\repl\db2006
mongod --port <span class="hljs-number">2006</span> --dbpath=E:\repl\db2006  --shardsvr --replSet=config
</code></pre>
<pre><code class="lang-js"># mongo localhost:2005
rs.initiate({_id: &apos;config&apos;, members: [{_id: 0, host: &apos;localhost:2005&apos;}, {_id: 1, host: &apos;localhost:2006&apos;}]})
rs.isMaster() #&#x67E5;&#x770B;&#x4E3B;&#x4ECE;&#x5173;&#x7CFB;
</code></pre>
<h4 id="t203.4.2 &#x521B;&#x5EFA;&#x8DEF;&#x7531;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x5E76;&#x4E14;&#x8FDE;&#x63A5;&#x914D;&#x7F6E;&#x670D;&#x52A1;&#x5668;">3.4.2 &#x521B;&#x5EFA;&#x8DEF;&#x7531;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x5E76;&#x4E14;&#x8FDE;&#x63A5;&#x914D;&#x7F6E;&#x670D;&#x52A1;&#x5668; <a href="#t203.4.2 &#x521B;&#x5EFA;&#x8DEF;&#x7531;&#x670D;&#x52A1;&#x5668;&#xFF0C;&#x5E76;&#x4E14;&#x8FDE;&#x63A5;&#x914D;&#x7F6E;&#x670D;&#x52A1;&#x5668;"> # </a></h4>
<p>&#x8DEF;&#x7531;&#x5668;&#x8C03;&#x7528;mongos&#x547D;&#x4EE4;</p>
<pre><code class="lang-js">mongos --port <span class="hljs-number">2006</span> --configdb config/localhost:<span class="hljs-number">2005</span>,<span class="hljs-attr">localhost</span>:<span class="hljs-number">2006</span>
</code></pre>
<h4 id="t213.4.3 &#x6DFB;&#x52A0;&#x5206;&#x7247;&#x6570;&#x636E;&#x5E93;">3.4.3 &#x6DFB;&#x52A0;&#x5206;&#x7247;&#x6570;&#x636E;&#x5E93; <a href="#t213.4.3 &#x6DFB;&#x52A0;&#x5206;&#x7247;&#x6570;&#x636E;&#x5E93;"> # </a></h4>
<pre><code class="lang-js">mongo localhost:<span class="hljs-number">2006</span>
use admin
&gt; db.runCommand({ <span class="hljs-attr">addshard</span>: <span class="hljs-string">&apos;shard1/localhost:2001,localhost:2002&apos;</span>})
&gt; db.runCommand({ <span class="hljs-attr">addshard</span>: <span class="hljs-string">&apos;shard2/localhost:2003,localhost:2004&apos;</span>})
</code></pre>
<h4 id="t223.4.5 &#x5728;&#x8DEF;&#x7531;&#x670D;&#x52A1;&#x5668;&#x6253;&#x5F00;&#x6570;&#x636E;&#x5206;&#x7247;&#x529F;&#x80FD;">3.4.5 &#x5728;&#x8DEF;&#x7531;&#x670D;&#x52A1;&#x5668;&#x6253;&#x5F00;&#x6570;&#x636E;&#x5206;&#x7247;&#x529F;&#x80FD; <a href="#t223.4.5 &#x5728;&#x8DEF;&#x7531;&#x670D;&#x52A1;&#x5668;&#x6253;&#x5F00;&#x6570;&#x636E;&#x5206;&#x7247;&#x529F;&#x80FD;"> # </a></h4>
<pre><code class="lang-js">use admin;
&gt; db.runCommand({ <span class="hljs-attr">enablesharding</span>: <span class="hljs-string">&apos;school&apos;</span>})
&gt; db.runCommand({ <span class="hljs-attr">shardcollection</span>: <span class="hljs-string">&apos;school.students&apos;</span>, <span class="hljs-attr">key</span>: {<span class="hljs-attr">name</span>: <span class="hljs-number">1</span>}})
</code></pre>
<h2 id="t234. &#x53C2;&#x8003;">4. &#x53C2;&#x8003; <a href="#t234. &#x53C2;&#x8003;"> # </a></h2>
<ul>
<li><a href="https://docs.mongodb.com/manual/reference/configuration-options/">configuration-options</a></li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
